1   /*
2    * Copyright (C) 2007 The Guava Authors
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  
17  package com.google.common.eventbus;
18  
19  import com.google.common.collect.Lists;
20  
21  import junit.framework.TestCase;
22  
23  import java.util.List;
24  import java.util.concurrent.Executor;
25  
26  /**
27   * Test case for {@link AsyncEventBus}.
28   *
29   * @author Cliff Biffle
30   */
31  public class AsyncEventBusTest extends TestCase {
32    private static final String EVENT = "Hello";
33  
34    /** The executor we use to fake asynchronicity. */
35    private FakeExecutor executor;
36    private AsyncEventBus bus;
37  
38    @Override protected void setUp() throws Exception {
39      super.setUp();
40      executor = new FakeExecutor();
41      bus = new AsyncEventBus(executor);
42    }
43  
44    public void testBasicDistribution() {
45      StringCatcher catcher = new StringCatcher();
46      bus.register(catcher);
47  
48      // We post the event, but our Executor will not deliver it until instructed.
49      bus.post(EVENT);
50  
51      List<String> events = catcher.getEvents();
52      assertTrue("No events should be delivered synchronously.",
53          events.isEmpty());
54  
55      // Now we find the task in our Executor and explicitly activate it.
56      List<Runnable> tasks = executor.getTasks();
57      assertEquals("One event dispatch task should be queued.", 1, tasks.size());
58  
59      tasks.get(0).run();
60  
61      assertEquals("One event should be delivered.", 1, events.size());
62      assertEquals("Correct string should be delivered.", EVENT, events.get(0));
63    }
64  
65    /**
66     * An {@link Executor} wanna-be that simply records the tasks it's given.
67     * Arguably the Worst Executor Ever.
68     *
69     * @author cbiffle
70     *
71     */
72    public static class FakeExecutor implements Executor {
73      List<Runnable> tasks = Lists.newArrayList();
74  
75      @Override
76      public void execute(Runnable task) {
77        tasks.add(task);
78      }
79  
80      public List<Runnable> getTasks() {
81        return tasks;
82      }
83    }
84  
85  }